package cn.iocoder.yudao.module.system.dal.dataobject.userassetscode;

import lombok.*;
import java.time.LocalDateTime;
import com.baomidou.mybatisplus.annotation.*;
import com.baomidou.mybatisplus.annotation.IdType;
import cn.iocoder.yudao.framework.mybatis.core.dataobject.BaseDO;

/**
 * 兑换码使用记录 DO
 *
 * @author 系统开发团队
 */
@TableName("ai_user_assets_code_usage_log")
@KeySequence("ai_user_assets_code_usage_log_seq") // 用于 Oracle、PostgreSQL、Kingbase、DB2、H2 数据库的主键自增。如果是 MySQL 等数据库，可不写。
@Data
@EqualsAndHashCode(callSuper = true)
@ToString(callSuper = true)
@Builder
@NoArgsConstructor
@AllArgsConstructor
public class UserAssetsCodeUsageLogDO extends BaseDO {

    /**
     * 主键ID
     */
    @TableId(type = IdType.AUTO)
    private Long id;

    /**
     * 兑换码ID，关联ai_user_assets_code.id
     */
    private Integer codeId;

    /**
     * 兑换码
     */
    private String code;

    /**
     * 使用者用户ID
     */
    private Long userId;

    /**
     * 使用者用户名
     */
    private String username;

    /**
     * 用户类型：1-管理员用户，2-会员用户
     */
    private Integer userType;

    /**
     * 使用者IP地址
     */
    private String userIp;

    /**
     * 用户代理信息
     */
    private String userAgent;

    /**
     * 设备信息JSON格式
     */
    private String deviceInfo;

    /**
     * 使用时间
     */
    private LocalDateTime usageTime;

    /**
     * 获得的资源信息JSON格式
     */
    private String assetsReceived;

    /**
     * 套餐ID
     */
    private Integer changeId;

    /**
     * 套餐名称
     */
    private String changeName;

    /**
     * 客户ID
     */
    private Integer customerId;

    /**
     * 客户名称
     */
    private String customerName;

    /**
     * 使用结果：1-成功，0-失败
     */
    private Integer usageResult;

    /**
     * 失败原因
     */
    private String failureReason;

    /**
     * 链路追踪ID
     */
    private String traceId;

}